## Lab 4 COMPENG 3DQ5

Joshua Umansky, George Wahba 400234265, 400371904 McMaster University COMPENG 3DQ5 For exercise one, we implemented a design in order to overwrite the data stored in a dual access ROM. This was completed in 512 clock cycles, which is optimised to be the fastest possible way of implementing. This was done by having a read, and write clock cycle, alternating between the two methods. As seen in experiment.sv, register total for this implementation is solely restricted to the following values;

- Read address (9)
- Read\_address256 (9)
- Write\_enable\_a (2)
- Write\_enable\_b (2)
- States (4)

Figure 1 displays the critical path and timing information, this takes information from the state and writes to the ROM.



Figure 1

From Quartus, the amount of logic elements required for our design is 130, while this is larger than required, we designed our assigned conditions for writing to check if enable is one, which increases power efficiency as the ROM's aren't constantly being written too.